# AN10915 Using the LPC1700 power modes Rev. 01 – 25 February 2010

**Application note** 

#### **Document information**

| Info     | Content                                                                                                                                                                                       |
|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Keywords | LPC1700, Low Power Modes, Power Consumption, code example                                                                                                                                     |
| Abstract | This application note attempts to introduce the various low power modes of the LPC1700 series, the steps required to enter the low power modes and helpful hints to reduce power consumption. |
|          | This application note also provides a software example to enter the low power modes, and demonstrates how to measure the power consumption using the Keil MCB1700 board.                      |



**Revision history** 

| Rev | Date     | Description       |
|-----|----------|-------------------|
| 01  | 20100225 | Initial revision. |

# **Contact information**

For additional information, please visit: <u>http://www.nxp.com</u>

For sales office addresses, please send an email to: <a href="mailto:salesaddresses@nxp.com">salesaddresses@nxp.com</a>

AN10915\_1

**Application note** 

All information provided in this document is subject to legal disclaimers.

# 1. Introduction

The LPC1700 microcontroller family is based on the ARM Cortex-M3 CPU architecture for embedded applications featuring a high level of support block integration and low power consumption. The LPC1700 microcontrollers incorporate key features like the AHB Matrix, Nested Vectored Interrupt Controller (NVIC) integrated with a SYSTICK timer, Wakeup Interrupt Controller (WIC), Memory Protection Unit (MPU), four reduced power modes, and a wide range of peripherals, making this simply the most powerful series of Cortex-M3 based microcontrollers in the marketplace.

The peripheral complement of the LPC1700 series includes up to 512 kB of flash memory, up to 64 kB of data memory, Ethernet MAC, USB Host/Device/OTG interface, 8-channel general purpose DMA controller, 4 UARTs, 2 CAN channels, 2 SSP controllers, SPI interface, 3 I<sup>2</sup>C interfaces, 2-input plus 2-output I2S interface, 8 channel 12-bit ADC, 10-bit DAC, motor control PWM, Quadrature Encoder interface, 4 general purpose timers, 6-output general purpose PWM, ultra-low power RTC with separate battery supply, and up to 70 general purpose I/O pins.

The LPC1700 series targets a wide range of applications, including eMetering, lighting, industrial networking, alarm systems, white goods and motor control.

This application note attempts to introduce the various low power modes of the LPC1700 series, the steps required to enter the low power modes and helpful hints to reduce power consumption. This application note also provides a software example to enter the low power modes, and demonstrates how to measure the power consumption using the Keil MCB1700 board.

The various topics covered in this application note are as follows:

- 1. LPC1700 Power Structure and Management
- 2. Entering low power modes and code example
- 3. Additional hints to reduce power consumption
- 4. Low power mode demo using the Keil MCB1700 Board

# 2. Power structure and management

The following section covers the following topics:

- Power domains
- Low power down modes

#### 2.1 Power domains

There are 5 main power domains in the LPC1700

- 1. V<sub>DD(reg)(3V3)</sub> on-chip voltage regulator (2.4 V to 3.6 V)
- 2. V<sub>DD(3V3)</sub>- I/O pads (2.4 V to 3.6 V)
- 3. VBAT (2.1 V to 3.6 V) Power only to the RTC and Backup Registers
- 4. VDDA (2.7 V to 3.6 V) Analog Supply Power to 12 Bit ADC
- 5. VREFP (2.7 V to 3.6 V) Analog Reference Voltage to 12 Bit ADC

The LPC1700 implements a separate VBAT power domain in order to allow turning off power to the bulk of the device while maintaining operation of the Real Time Clock. The VBAT pin supplies power only to the RTC domain. Whenever the device core power is present, that power is used to operate the RTC, causing no power drain from a battery when main power is available (see Fig 1).



### 2.2 Power modes

On the LPC1700 series, there are four reduced power modes: Sleep, Deep-Sleep, Power-down, and Deep Power-down modes.

The following sections cover the power reduction modes for the LPC1700.

#### 2.2.1 Sleep mode

In Sleep mode, execution of instructions is suspended (clock to the core is stopped) until either a Reset or an interrupt occurs. Peripheral functions continue operation during Sleep mode and may generate interrupts to cause the processor to resume execution. The GPDMA may operate in Sleep mode to access AHB SRAMs and peripherals with GPDMA support, but may not access the flash memory or the main SRAM, which are disabled in order to save power. Sleep mode eliminates dynamic power used by the processor itself, memory systems and related controllers, and internal buses.

Wake-up from Sleep mode will occur whenever any enabled interrupt occurs.

#### 2.2.2 Deep-sleep mode

When the chip enters the Deep Sleep mode, the main oscillator is powered down, and nearly all clocks are stopped. The IRC remains running and can be configured to drive the Watchdog Timer, allowing the Watchdog to wake up the CPU. The 32 kHz RTC oscillator is not stopped and RTC interrupts may be used as a wakeup source. The flash is left in the standby mode allowing a quick wakeup. The PLLs are automatically turned off and disconnected. The processor state and registers, peripheral registers, and internal SRAM values are preserved throughout Deep Sleep mode and the logic levels of chip pins remain static. The Deep Sleep mode can be terminated and normal operation resumed by either a Reset or certain specific interrupts that are able to function without clocks. Since all dynamic operation of the chip is suspended, Deep Sleep mode reduces chip power consumption to a very low value.

On the wake-up of Deep Sleep mode, if the IRC was used before entering Deep Sleep mode, a 2-bit IRC timer starts counting and the code execution and peripherals activities will resume after the timer expires (4 cycles). If the main external oscillator was used, the 12-bit main oscillator timer starts counting and the code execution will resume when the timer expires (4096 cycles). The user must remember to reconfigure any required PLLs and clock dividers after the wake-up.

Wake-up from Deep Sleep mode can be brought about by NMI, External Interrupts EINT0 through EINT3, GPIO interrupts, the Ethernet Wake-on-LAN interrupt, Brownout Detect, an RTC Alarm interrupt, a Watchdog Timer timeout, a USB input pin transition (USB activity interrupt), or a CAN input pin transition (CAN Activity Interrupt), generated by activity on the CAN bus pins. In addition, the watchdog timer can wake up the part from Deep Sleep mode if the watchdog timer is being clocked by the IRC oscillator.

#### 2.2.3 Power-down mode

Power-down mode does everything that Deep Sleep mode does, but also turns off the flash memory. This saves more power, but requires waiting for resumption of flash operation before execution of code or data access in the flash memory can be accomplished. When the chip enters Power-down mode, the IRC, the main oscillator, and all clocks are stopped. The RTC remains running if it has been enabled and RTC interrupts may be used to wake up the CPU. The flash is forced into Power-down mode. The PLLs are automatically turned off and disconnected. The CCLK and USBCLK clock dividers automatically get reset to zero. Upon wake-up from Power-down mode, if the

IRC was used before entering Power-down mode, after IRC-start-up time (about 60  $\mu$ s), the 2-bit IRC timer starts counting and expiring in 4 cycles. Code execution can then be resumed immediately following the expiration of the IRC timer if the code was running from SRAM. In the meantime, the flash wake-up timer measures flash start-up time of about 100  $\mu$ s. When it times out, access to the flash is enabled. The user must remember to reconfigure any required PLLs and clock dividers after the wake-up.

Wake-up from Power-down mode can be brought about by NMI, External Interrupts EINT0 through EINT3, GPIO interrupts, the Ethernet Wake-on-LAN interrupt, Brownout Detect, an RTC Alarm interrupt, a Watchdog Timer timeout, a USB input pin transition (USB activity interrupt), or a CAN input pin transition (CAN Activity Interrupt), generated by activity on the CAN bus pins.

#### 2.2.4 Deep power-down mode

In Deep Power-down mode, power is shut off to the entire chip with the exception of the Real-Time Clock, the RESET pin, the WIC, and the RTC backup registers. To optimize power conservation, the user has the additional option of turning off or retaining power to the 32 kHz oscillator. It is also possible to use external circuitry to turn off power to the on-chip regulator via the  $V_{DD(REG)(3V3)}$  pins after entering Deep power-down mode. Power to the on-chip regulator must be restored before device operation can be restarted.

Wake-up from Deep power-down mode will occur when an external reset signal is applied, or the RTC interrupt is enabled and an RTC interrupt is generated.

# 3. Entering low power modes and code example

This section describes the mechanism to put the LPC1700 into the four low power modes (sleep, deep-sleep, power-down, deep power-down).

# 3.1 System Control Register (SCR)

The SCR register controls features of entry to and exit from low power modes.

Sleep mode and Deep Sleep mode are selected by the SLEEPDEEP bit in the Cortex-M3 System Control Register (SCR).

The bit assignments are shown in Fig 2.



If the SLEEPDEEP bit in the Cortex-M3 System Control Register (SCR) is 0, Sleep mode is selected.

If the SLEEPDEEP bit in the Cortex-M3 System Control Register (SCR) is 1, Deep-sleep mode is selected.

If the SLEEPONEXIT bit of the SCR is set to 1, when the processor completes the execution of an exception handler and immediately enters Sleep mode. This mechanism is useful for applications that only require the processor to run when an exception occurs. If SLEEPON EXIT bit is set in the System Control Register, core will automatically enter the low power mode once the ISR has completed. This allows a low power application to be entirely interrupt-driven, so that the Cortex core will wake up, run the appropriate code and then re-enter the mode with minimal code being used for power management

#### 3.2 PCON register

Power down and Deep Power-down modes are selected by the PM1 and PM0 bits in the PCON register and the SLEEPDEEP bit in the Cortex-M3 System Control Register (SCR) is set to 1.

| Bit   | Symbol  | Description                                                                                                                                                                                                                                                                                                                              | Reset value |
|-------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 0     | PM0     | Power mode control bit 0. This bit controls entry to the Power-down mode. See Section 4–8.7.1 below for details.                                                                                                                                                                                                                         | 0           |
| 1     | PM1     | Power mode control bit 1. This bit controls entry to the Deep<br>Power-down mode. See Section 4–8.7.1 below for details.                                                                                                                                                                                                                 | 0           |
| 2     | BODRPM  | Brown-Out Reduced Power Mode. When BODRPM is 1, the<br>Brown-Out Detect circuitry will be turned off when chip Power-down<br>mode or Deep Sleep mode is entered, resulting in a further reduction<br>in power usage. However, the possibility of using Brown-Out Detect as<br>a wake-up source from the reduced power mode will be lost. | 0           |
|       |         | When 0, the Brown-Out Detect function remains active during<br>Power-down and Deep Sleep modes.                                                                                                                                                                                                                                          |             |
|       |         | See the System Control Block chapter for details of Brown-Out<br>detection.                                                                                                                                                                                                                                                              |             |
| 3     | BOGD    | Brown-Out Global Disable. When BOGD is 1, the Brown-Out Detect<br>circuitry is fully disabled at all times, and does not consume power.                                                                                                                                                                                                  | 0           |
|       |         | When 0, the Brown-Out Detect circuitry is enabled.                                                                                                                                                                                                                                                                                       |             |
|       |         | See the System Control Block chapter for details of Brown-Out<br>detection.                                                                                                                                                                                                                                                              |             |
| 4     | BORD    | Brown-Out Reset Disable. When BORD is 1, the BOD will not reset the device when the $V_{DD(REG)(3V3)}$ voltage dips goes below the BOD reset trip level. The Brown-Out interrupt is not affected.                                                                                                                                        | 0           |
|       |         | When BORD is 0, the BOD reset is enabled.                                                                                                                                                                                                                                                                                                |             |
|       |         | See the Section 3-5 for details of Brown-Out detection.                                                                                                                                                                                                                                                                                  |             |
| 7:3   | -       | Reserved, user software should not write ones to reserved bits. The<br>value read from a reserved bit is not defined.                                                                                                                                                                                                                    | NA          |
| 8     | SMFLAG  | Sleep Mode entry flag. Set when the Sleep mode is successfully<br>entered. Cleared by software writing a one to this bit.                                                                                                                                                                                                                | 0 [1][2]    |
| 9     | DSFLAG  | Deep Sleep entry flag. Set when the Deep Sleep mode is successfully<br>entered. Cleared by software writing a one to this bit.                                                                                                                                                                                                           | 0 [1][2]    |
| 10    | PDFLAG  | Power-down entry flag. Set when the Power-down mode is successfully entered. Cleared by software writing a one to this bit.                                                                                                                                                                                                              |             |
| 11    | DPDFLAG | Deep Power-down entry flag. Set when the Deep Power-down mode<br>is successfully entered. Cleared by software writing a one to this bit.                                                                                                                                                                                                 |             |
| 31:12 | . T.    | Reserved, user software should not write ones to reserved bits. The value read from a reserved bit is not defined.                                                                                                                                                                                                                       | NA          |

[3] Hardware reset only for a power-up event on Vbat.

#### Fig 3. LPC1700 Power Mode Control Register (PCON)

The PCON register also contains flags that indicate whether entry into each reduced power mode actually occurred.

# 3.3 Wait For Interrupt (WFI) instruction

Execution of the WFI instruction will cause immediate entry to any of the four reduced power modes based on the SLEEPDEEP bit and PCON Register settings mentioned above.

The WFI instruction is a Cortex-M3 instruction which cannot be directly accessible by ANSI C. The CMSIS (Cortex Microcontroller Software Interface Standard) provides an intrinsic function to generate a WFI instruction and supported by C compiler.

If a C compiler does not support the WFI intrinsic function, then the user will have to use inline assembler to access WFI instruction.

Fig 4 below shows the encoding for the three reduced power modes supported by the LPC1700.

| Table 45. | Encoding of reduced power modes                                                                                                             |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------|
| PM1, PM0  | Description                                                                                                                                 |
| 00        | Execution of WFI or WFE enters either Sleep or Deep Sleep mode as defined by the<br>SLEEPDEEP bit in the Cortex-M3 System Control Register. |
| 01        | Execution of WFI or WFE enters Power-down mode if the SLEEPDEEP bit in the<br>Cortex-M3 System Control Register is 1.                       |
| 10        | Reserved, this setting should not be used.                                                                                                  |
| 11        | Execution of WFI or WFE enters Deep Power-down mode if the SLEEPDEEP bit in<br>the Cortex-M3 System Control Register is 1.                  |

#### Fig 4. LPC1700 Encoding of reduced power modes

#### 3.4 Code example

The code below demonstrates the entry into each of the four low power modes. The code below is used in the low power mode demo which will be covered later.

#### 3.4.1 Sleep mode

```
/*Clear the PCON*/
LPC_SC->PCON = 0x0;
/*Clear the SLEEPDEEP bit in the Cortex M3 System Control Register*/
SCB->SCR = 0x0;
/*WFI instruction*/
WFI();
```

Fig 5. LPC1700 code example (Sleep mode)

#### 3.4.2 Deep-sleep mode

```
/*Set SLEEPDEEP bit in the Cortex M3 System Control Register*/
SCB->SCR |= 0x04;
/*PCON register + disable BOD*/
LPC_SC->PCON = 0x8;
/*WFI instruction*/
__WFI();
```

Fig 6. LPC1700 code example (Deep-sleep mode)

#### 3.4.3 Power-down mode

```
/*Set SLEEPDEEP bit in the Cortex M3 System Control Register*/
SCB->SCR |= 0x04;
/*PCON register + disable BOD*/
LPC_SC->PCON = 0x9;
/*WFI instruction*/
__WFI();
```

Fig 7. LPC1700 code example (Power-down mode)

#### 3.4.4 Deep Power-down Mode

```
/*Set SLEEPDEEP bit in the Cortex M3 System Control Register*/
SCB->SCR |= 0x04;
/*PCON register*/
LPC_SC->PCON = 0x3;
/*WFI instruction*/
__WFI();
```

Fig 8. LPC1700 code example (Deep power-down mode)

# 4. Additional tips to reduce power consumption

On the LPC1700 series, the current consumption can be further reduced by considering the following points:

# 4.1 CPU clock rate

On the LPC1700, the CPU clock rate can be controlled as needed by changing clock sources, reconfiguring PLL values, and/or altering the CPU clock divider value. This allows a trade-off of power versus processing speed based on application requirements. Lowering the PLL0's output frequency (FCCO, 275 MHz to 550 MHz) can also save power.

An 8-bit CPU clock divider allows a range of options, including slowing CPU operation to a low rate for temporary power savings without turning off PLL0.



# 4.2 Peripheral clock selection register (PCLKSEL0/1)

A pair of bits in a Peripheral Clock Selection register controls the rate of the clock signal that will be supplied to the corresponding peripheral (see Fig 9). Depending application requirements, the user can use the PCLKSEL0/1 registers to reduce the peripheral clock frequency to reduce power. See the LPC17xx User Manual for details.

# 4.3 Peripheral power control register (PCONP)

Peripherals Power Control Register contains control bits that enable and disable individual peripheral functions, allowing elimination of power consumption by peripherals that are not needed. This feature allows individual peripherals to be turned off if they are not needed in the application, resulting in additional power savings. Each bit in PCONP controls one peripheral. If a peripheral control bit is 1, that peripheral is enabled. If a peripheral control bit is 0, that peripheral's clock is disabled (gated off) to conserve power. For example, if bit 19 is 1, the I2C1 interface is enabled. If bit 19 is 0, the I2C1 interface is disabled. Note that valid read from a peripheral register and valid write to a peripheral register is possible only if that peripheral is enabled in the PCONP register. See the LPC17xx User Manual for details.

#### 4.4 Miscellaneous

#### 4.4.1 Flash accelerator

Enable the flash accelerator if the application is running from the on-chip flash. Enabling the flash accelerator will enable various buffers and reduces the number of flash fetches thereby reducing power consumption.

#### 4.4.2 Brown-Out Detect (BOD)

The Brown-out Detect (BOD) circuit is turned on by default and can increase the static current (deep-sleep and power-down) by 40  $\mu$ A. If the BOD is not needed, it can be disabled by using the PCON register (see Fig 3).

#### 4.4.3 Software

Most embedded applications terminate with a while(1) loop, and they service interrupts whenever needed. In this case, code is still constantly fetched from the on-chip flash and executed which adds to the power consumption. A better solution would be to switch to the sleep power saving mode and then wait for interrupts. An interrupt from a peripheral would then wake the device from Sleep mode. Considerable power savings can be achieved by keeping the core in Sleep mode while it is waiting for interrupts.

#### 4.4.4 USB clock divider

On the LPC1700, USB clock divider (see Fig 9) is implemented to create the USB clock from the PLL0 output when the USB PLL1 is not being used. If USB PLL1 is not used in an application, then the pllclk (see Fig 9) will be feed to the USB clock divider and increase the dynamic current by approximately 5 mA to 7 mA. User can disconnect the USB clock divider from pllclk by connecting the USB PLL (PLL1). There is no need to enable the USB PLL1. The code example below shows the steps needed to disconnect the USB clock divider from pllclk. This hint is useful for applications not using the USB interface.

```
/*Disconnect the USB clock divider from the PLL0 by connecting PLL1*/
/*No need to enable the USB PLL1*/
/*This reduces the sleep current by 4 mA*/
LPC_SC->PLL1CON = 2; // only connect
LPC_SC->PLL1FEED = 0xaa;
LPC_SC->PLL1FEED = 0x55;
while ( ((LPC_SC->PLL1STAT & (1 << 9)) == 0) ); // Check connect bit status</pre>
```

Fig 10. LPC1700 code example – USB clock divider

#### 4.4.5 Port pins

User can take further steps to reduce current consumption on the 3.3 V rail ( $V_{DD(3V3)}$  - supply voltage for IO ports) in the low power modes. The general purpose port pins on the LPC1700 series have programmable internal pull-ups enabled by default. Before entering low power modes, user can reduce the  $V_{DD(3V3)IO}$  supply voltage current as follows:

- 1. All General Purpose I/O pins (GPIO) default to input with pull-up resistor enabled. Using the PINMODEx registers, first, disable the internal pull-ups on all general port pins. Second, configure the IOs as GPIO outputs and drive them low, OR
- 2. Using the PINMODEx registers, first disable the internal pull-ups on all general port pins. Second, configure the IOs as GPIO inputs and using an external resistor, pull the IOs high or low.
- 3. Using an external resistor, pull the TCK pin (JTAG Test Clock) low. If floating, the IO current increases by 40  $\mu$ A.

Please note that in deep power-down mode, state of the port pins does not affect the current consumption and the steps mentioned above do not need to be considered in this mode.

#### 4.4.6 Debug notes

The user should be aware of certain limitations during debugging. The most important is that, due to limitations of the Cortex-M3 integration, the LPC17xx cannot wake up in the usual manner from Deep Sleep and Power-down modes. It is recommended not to use these modes during debug. Once an application is downloaded via JTAG/SWD interface, the USB to SWD/JTAG debug adapter (Keil ULINK2 for example) should be removed from the target board, and thereafter, power cycle the LPC17xx to allow wake-up from deep sleep and power-down modes. Another issue is that debug mode changes the way in which reduced power modes are handled by the Cortex-M3 CPU. This causes power modes at the device level to be different from normal modes operation. These differences mean that power measurements should not be made while debugging, the results will be higher than during normal operation in an application.

# 5. Low power mode demo

#### 5.1 Requirements

#### 5.1.1 Hardware

Keil MCB1700 Development Board (see Fig 11).

Keil ULINK2 USB -JTAG Adapter

RS-232 serial cable

**Note:** Instead of using the ULINK2 JTAG module to program the LPC1700, you can use an RS-232 serial cable along with the FlashMagic programming tool that is available at no charge at <a href="http://www.nxp.com/redirect/flashmagictool.com/">http://www.nxp.com/redirect/flashmagictool.com/</a>

#### 5.1.2 Software

Keil uVision4 (evaluation version will work for the demo).

The project demo is CMSIS (Cortex Microcontroller Software Interface Standard) compliant.

TeraTerm or HyperTerminal window is needed to display the options to enter low power modes.

#### 5.2 Objective

The objective of the demo is to allow LPC1700 users to enter and wake-up from the low power modes, and demonstrates how to measure the power consumption using the Keil MCB1700 board. In addition, the demo allows users to evaluate the active mode current for frequencies 12 MHz, 48 MHz, and 100 MHz. The following sections provide the necessary steps to set-up the low power mode demo.

#### 5.2.1 Hardware set-up

The Keil MCB1700 has jumpers available to allow users to measure the  $V_{DD(reg)(3V3)}$  current and the VBAT current. Users can connect ammeter on these jumpers to measure the  $V_{DD(reg)(3V3)}$  and the VBAT currents.

In this demonstration, following options are available to wake-up the device from the low power modes:

- 1. The UART0 (press any key on the keyboard to generate UART0 interrupt) or EINT0 push button or RESET push button can be used to wake-up the LPC1700 when in Sleep mode.
- 2. The EINT0 or RESET push button can be used to wake-up the LPC1700 when in deep-sleep and power-down modes.
- 3. The RESET push button can be used to wake-up the LPC1700 when in deep power-down mode.

The ISP and RST jumpers should be removed from the MCB1700 Keil board.

Make sure there is a jumper on INT0.

The COM0 (UART0) will be used to display low power mode menu.

As previously mentioned in the Debug Notes section, once the application is downloaded via JTAG/SWD interface, the Keil ULINK2 should be kept removed from the target board, and thereafter, power cycle the LPC17xx to allow wake-up from deep sleep and power-down modes.

AN10915

One important point to be aware of is that when the Keil MCB1700 board is powered via the USB cable, the external 50 MHz oscillator is powered on and constantly clocks the ENET\_REF\_CLK pin on the LPC1700. The clocking of the ENET\_REF\_CLK pin raises the power consumption by approximately 140  $\mu$ A and there is no separate jumper to turn off the 50 MHz oscillator. To accurately measure and evaluate the power consumption on the Keil MCB1700 board, the 50 MHz oscillator should be de-soldered and removed from the board (see Fig 11).



#### 5.2.2 Terminal program settings

This demo uses the Tera Term and the settings for the serial port are shown in Fig 12).

|                         | Tera Term: Serial port | setup   |        |  |
|-------------------------|------------------------|---------|--------|--|
|                         | Port:                  | COM1 -  | ок     |  |
|                         | Baud rate:             | 9600 🔽  |        |  |
|                         | Data:                  | 8 bit 🔹 | Cancel |  |
|                         | Parity:                | none 💌  |        |  |
|                         | Stop:                  | 1 bit 💌 | Help   |  |
|                         | Flow control:          | none 🔻  |        |  |
|                         | Transmit delay         |         | ;/line |  |
| ig 12. Terminal program | settings               |         |        |  |

#### 5.2.3 Output

The output of the code is shown in Fig 13.

The menu below instructs how to evaluate the active mode current for frequencies 12 MHz, 48 MHz, and 100 MHz, and lastly, shows how to select and exit the four low power modes.

```
Welcome to the LPC1700 Low Power Modes
Default Set-up is Active Mode, Core Freq 48 MHz, PLL0 Enabled, Uart0 Enabled
1. Active Mode, Core Freq 12 MHz, PLL0 Disabled, Uart0 Enabled
Enter >> Hit a or A and To Return to Main Menu >> Hit Reset
2. Active Mode, Core Freq 100 MHz, PLL Disabled, Uart0 Enabled
Enter >> Hit b or B and To Return to Main Menu >> Hit Reset
3. Sleep Mode, Core Freq 48 MHz, PLL0 Enabled, Pclk 6 MHz, Uart0 Enabled
Enter Mode >> Hit s or S and Exit Mode >> Hit any key or EINT0 or Reset
4. Deep Sleep Mode
Enter Mode >> Hit t or T and Exit Mode >> hit EINT0 or Reset
5. Power-down Mode
Enter Mode >> Hit p or P and Exit Mode >> hit EINT0 or Reset
6. Deep Power-down Mode
Enter Mode >> Hit d or D and Exit Mode >> Hit reset
```

AN10915\_1

#### 5.3 Power measurements

<u>Table 1</u> shows the typical power consumption measurement made using the demo on the MCB1700 Keil board:

**Typical power consumption** Table 1. LPC1700 Active Power Modes Ireg(3V3) current Active mode (12 MHz, PLL disabled, all 7 mA peripherals off except UART0) Active mode (48 MHz, PLL enabled, all peripherals 24 mA off except UART0) Active mode (100 MHz, PLL enabled, all 43 mA peripherals off except UART0) LPC1700 Low Power Modes Ireg(3V3) current Sleep Mode (48 MHz, PLL enabled, All peripherals off except UART0) 14 mA Deep-Sleep Mode (BOD disabled) 240 µA Power-down Mode (BOD disabled) 37 µA LPC1700 Low Power Modes **Ivbat current** Deep power-down mode 500 nA

<u>**Conditions:**</u>  $V_{reg(3V3)} = 3.3 V$ , VBAT = 3.3 V, Temperature = 25 °C, All peripherals disabled except UART0 (9600 baud-rate) running in active and sleep modes, Peripheral Clocks (pclk) = cclk/8, All pins (except UART0 pins) configured as GPIO outputs and driven low, internal pull-ups disabled, USB clock divider disconnected. 50 MHz oscillator on the Keil MCB1700 removed.

# AN10915 Using the LPC1700 power modes

# 6. Legal information

#### 6.1 Definitions

**Draft** — The document is a draft version only. The content is still under internal review and subject to formal approval, which may result in modifications or additions. NXP Semiconductors does not give any representations or warranties as to the accuracy or completeness of information included herein and shall have no liability for the consequences of use of such information.

# 6.2 Disclaimers

Limited warranty and liability — Information in this document is believed to be accurate and reliable. However, NXP Semiconductors does not give any representations or warranties, expressed or implied, as to the accuracy or completeness of such information and shall have no liability for the consequences of use of such information.

In no event shall NXP Semiconductors be liable for any indirect, incidental, punitive, special or consequential damages (including - without limitation - lost profits, lost savings, business interruption, costs related to the removal or replacement of any products or rework charges) whether or not such damages are based on tort (including negligence), warranty, breach of contract or any other legal theory.

Notwithstanding any damages that customer might incur for any reason whatsoever, NXP Semiconductors' aggregate and cumulative liability towards customer for the products described herein shall be limited in accordance with the Terms and conditions of commercial sale of NXP Semiconductors.

**Right to make changes** — NXP Semiconductors reserves the right to make changes to information published in this document, including without limitation specifications and product descriptions, at any time and without notice. This document supersedes and replaces all information supplied prior to the publication hereof.

**Suitability for use** — NXP Semiconductors products are not designed, authorized or warranted to be suitable for use in medical, military, aircraft, space or life support equipment, nor in applications where failure or malfunction of a NXP Semiconductors product can reasonably be expected to result in personal injury, death or severe property or environmental damage. NXP Semiconductors accepts no liability for inclusion and/or use of NXP Semiconductors products in such equipment or applications and therefore such inclusion and/or use is at the customer's own risk.

**Applications** — Applications that are described herein for any of these products are for illustrative purposes only. NXP Semiconductors makes no representation or warranty that such applications will be suitable for the specified use without further testing or modification.

NXP Semiconductors does not accept any liability related to any default, damage, costs or problem which is based on a weakness or default in the customer application/use or the application/use of customer's third party customer(s) (hereinafter both referred to as "Application"). It is customer's sole responsibility to check whether the NXP Semiconductors product is suitable and fit for the Application planned. Customer has to do all necessary testing for the Application in order to avoid a default of the Application and the product. NXP Semiconductors does not accept any liability in this respect.

**Export control** — This document as well as the item(s) described herein may be subject to export control regulations. Export might require a prior authorization from national authorities.

#### 6.3 Trademarks

Notice: All referenced brands, product names, service names and trademarks are property of their respective owners.

# 7. Contents

| 1.    | Introduction                                   | .3 |
|-------|------------------------------------------------|----|
| 2.    | Power structure and management                 | .4 |
| 2.1   | Power domains                                  | .4 |
| 2.2   | Power modes                                    | .5 |
| 2.2.1 | Sleep mode                                     | .5 |
| 2.2.2 | Deep-sleep mode                                |    |
| 2.2.3 | Power-down mode                                |    |
| 2.2.4 | Deep power-down mode                           | .6 |
| 3.    | Entering low power modes and code example      | .7 |
| 3.1   | System Control Register (SCR)                  | .7 |
| 3.2   | PCON register                                  | .7 |
| 3.3   | Wait For Interrupt (WFI) instruction           | .9 |
| 3.4   | Code example                                   |    |
| 3.4.1 | Sleep mode                                     | .9 |
| 3.4.2 | Deep-sleep mode                                | 10 |
| 3.4.3 | Power-down mode                                |    |
| 3.4.4 | Deep Power-down Mode                           |    |
| 4.    | Additional tips to reduce power consumption    | 11 |
| 4.1   | CPU clock rate                                 |    |
| 4.2   | Peripheral clock selection register (PCLKSEL0/ | 1) |
|       |                                                |    |
| 4.3   | Peripheral power control register (PCONP)      |    |
| 4.4   | Miscellaneous                                  |    |
| 4.4.1 | Flash accelerator                              |    |
| 4.4.2 | Brown-Out Detect (BOD)                         |    |
| 4.4.3 | Software                                       | 12 |
| 4.4.4 | USB clock divider                              |    |
| 4.4.5 | Port pins                                      | 13 |
| 4.4.6 | Debug notes                                    | 13 |
| 5.    | Low power mode demo                            |    |
| 5.1   | Requirements                                   | 14 |
| 5.1.1 | Hardware                                       | 14 |
| 5.1.2 | Software                                       | 14 |
| 5.2   | Objective                                      | 14 |
| 5.2.1 | Hardware set-up                                |    |
| 5.2.2 | Terminal program settings                      |    |
| 5.2.3 | Output                                         |    |
| 5.3   | Power measurements                             |    |
| 6.    | Legal information                              |    |
| 6.1   | Definitions                                    |    |
| 6.2   | Disclaimers                                    |    |
| 6.3   | Trademarks                                     | 18 |
| 7.    | Contents                                       | 19 |

Please be aware that important notices concerning this document and the product(s) described herein, have been included in the section 'Legal information'.

#### © NXP B.V. 2010.

#### All rights reserved.

For more information, please visit: http://www.nxp.com For sales office addresses, please send an please send an email to: salesaddresses@nxp.com

> Date of release: 25 February 2010 Document identifier: AN10915\_1